LeetCode 58. Length of Last Word

58. Length of Last Word(最后一个单词的长度)

链接

https://leetcode-cn.com/problems/length-of-last-word

题目

给定一个仅包含大小写字母和空格 ‘ ‘ 的字符串 s,返回其最后一个单词的长度。

如果字符串从左向右滚动显示,那么最后一个单词就是最后出现的单词。

如果不存在最后一个单词,请返回 0 。

说明:一个单词是指仅由字母组成、不包含任何空格的 最大子字符串。

示例:

输入: “Hello World”
输出: 5

思路

字符串题,只要注意到几处细节就不难。
我是从最后一位开始的,若最后一位为空格,则提前,提前到非空处,之后再按位查找,直到找到空格或者到字符串的开头为止。在按位查找的过程中增加一个num用于计数,最后输出num即可。

代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
public static int lengthOfLastWord(String s) {
if (s.length() < 1) {
return 0;
}
int end = s.length() - 1;
while (end >= 0 && s.charAt(end) == ' ') {
end--;
}
if (end < 0) {
return 0;
}
int num = 0;
while (end >= 0 && s.charAt(end) != ' ') {
end--;
num++;
}
return num;
}
---本文结束,感谢阅读---